When I disconnect/reconnect the kflop USB plug while my application is running, I am sometimes experiencing a deadlock. It seems the deadlock can occur either when unplugging the board or when reconnecting it. I don't see any deadlocking in the KMotion
application, only in my application.
I debugged (with native code debugging turned on) and got the stacktrace below. I do not see any other threads that are running in KMotion code, so I don't know why the lock is not released. Do you have any ideas how I can prevent this?
Worker Thread Worker Thread
CSyncObject::Lock
Normal
ntdll.dll!7753f8d1()
[Frames below may be incorrect and/or missing, no symbols loaded for ntdll.dll]
ntdll.dll!7753f8d1()
KernelBase.dll!75f3149d()
KMotionDLL.dll!CSyncObject::Lock(unsigned long dwTimeout) Line 42
KMotionDLL.dll!CKMotionDLL::Pipe(const char * s, int n, char * r, int * m) Line 348
KMotionDLL.dll!CKMotionDLL::ListLocations(int * nlocations, int * list) Line 116
KMotion_dotNet_Interop.dll!KM_dotnet_Interop_ListLocations(void * handle, int * nlocations, int * list) Line 328
External Code]
KMotion_dotNet.dll!KMotion_dotNet.KM_Controller.GetBoards(out int numberofboards) Line 873 + 0x26 bytes
SharedController.dll!LaserTech.eCut.KMController.CheckConnected() Line 1232 + 0x10 bytes
SharedController.dll!LaserTech.eCut.KMController.onStatusTimer(object sender, System.Timers.ElapsedEventArgs e) Line 353 + 0x5 bytes
External Code]
kernel32.dll!76f9336a()
ntdll.dll!77559f72()
ntdll.dll!77559f45()